aboutsummaryrefslogtreecommitdiff
path: root/src/pages/[...page].astro
blob: 42f84b327180113a0fb6b32eb6b94e693fe0a7b1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
---
import type { GetStaticPaths, InferGetStaticPropsType } from "astro";
import { getCollection } from "astro:content";
import Layout from "../layouts/BaseLayout.astro";
import Pagination from "../components/Pagination.astro";
import PostSummary from "../components/PostSummary.astro";

type Props = InferGetStaticPropsType<typeof getStaticPaths>;

export const getStaticPaths = (async ({ paginate }) => {
	const posts = await getCollection("blog");
	posts.sort((a, b) => b.data.pubDate.getTime() - a.data.pubDate.getTime());

	return paginate(posts, {
		pageSize: 10,
	});
}) satisfies GetStaticPaths;

const { page } = Astro.props;
---

<Layout>
	<section>
		{page.data.map((post) => <PostSummary post={post} />)}
	</section>

	<section>
		<Pagination nextUrl={page.url.next} prevUrl={page.url.prev} />
	</section>
</Layout>